<!DOCTYPE html>
<meta charset="utf-8" />
<meta viewport="width=device-width, initial-scale=1" />
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script type="module">
import { attachIframe, makeCleanup, getOppositeOrientation } from "./resources/orientation-utils.js";

promise_test(async t => {
  t.add_cleanup(makeCleanup());
  await test_driver.bless("request full screen")
  await document.documentElement.requestFullscreen();
  const value = await screen.orientation.lock('any');
  assert_equals(value, undefined);
}, "Test that screen.orientation.lock returns a promise which will be fulfilled with a void value.");

promise_test(async t => {
  t.add_cleanup(makeCleanup());
  await test_driver.bless("request full screen")
  await document.documentElement.requestFullscreen();
  const initialOrientation = screen.orientation.type;
  const orientations = [
    'any',
    'natural',
    'portrait',
    'landscape',
    'portrait-secondary',
    'landscape-primary',
    'landscape-secondary',
    'portrait-primary',
  ];
  for (const orientation of orientations) {
    try {
      await screen.orientation.lock(orientation);
    } catch(err) {
      if (err.name === "NotSupportedError") {
        continue;
      }
      assert_unreached("Unknown error: " + err);
    }
    const { type } = screen.orientation;
    switch (orientation) {
    case 'any':
      break;
    case 'natural':
      assert_true(type.endsWith("primary"), `Expected primary orientation for "${orientation}", got "${type}"`);
      break;
    case 'portrait':
      assert_true(type.startsWith("portrait"), `Expected portrait orientation for "${orientation}", got "${type}"`);
      break;
    case 'landscape':
      assert_true(type.startsWith("landscape"), `Expected landscape orientation for "${orientation}", got "${type}"`);
      break;
    default:
      assert_equals(type, orientation, "Expected orientation to change");
      break;
    }
    await screen.orientation.lock(initialOrientation);
  }
}, "Test that screen.orientation.lock returns a pending promise.");

promise_test(async t => {
  t.add_cleanup(makeCleanup());
  await test_driver.bless("request full screen")
  await document.documentElement.requestFullscreen();
  const initialType = screen.orientation.type;
  const newType = getOppositeOrientation();
  const p = screen.orientation.lock(newType);
  assert_equals(screen.orientation.type, initialType, "Must not change orientation until next spin of event loop");
  await p;
  const finalType = screen.orientation.type;
  assert_true(finalType.startsWith(newType), `Expected type to start with ${newType}, got "${finalType}"`);
}, "Test that screen.orientation.lock() is actually async");
</script>
